package cn.tedu.sp02.controller;
import cn.tedu.sp01.pojo.Item;
import cn.tedu.sp01.service.ItemService;
import cn.tedu.web.util.JsonResult;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Random;

@Slf4j
@RestController
public class ItemController {
    @Autowired
    private ItemService itemService;
    /* 获取订单商品列表*/
    @GetMapping("/{orderId}")
    public JsonResult<List<Item>> getItems(@PathVariable String orderId) throws InterruptedException {
        List<Item> items = itemService.getItems(orderId);
//                int i = 1/0;

         /*插入随机延迟，90%概率执行延迟*/
        if (Math.random() < 0.9) {
            /*定义随机延迟时长：0到5秒*/
            long t = new Random().nextInt(5000);
            /*在日志打印睡眠时间*/
            log.info("延迟时长(毫秒)： "+t);
            /*线程睡眠,有异常抛出异常*/
            Thread.sleep(t);
        }

        /*状态码code,data返回数据,msg提示信息(可有可无)*/
        return JsonResult.build().code(200).data(items);
    }
    /**
    @RequestParam 接收表单提交的名值对参数 k1=v1&k2=v2&k3=v3
    @PathVariable 接收路径参数
    @RequestBody 完整接收客户端提交的http协议体数据
     */
    /* 减少商品库存*/
    @PostMapping("/decreaseNumber")
    public JsonResult<?> decreaseNumber(@RequestBody List<Item> items) {
        itemService.decreaseNumber(items);
        /*没有数据返回,只有减少库存状态提示信息和提示信息*/
        return JsonResult.build().code(200).msg("减少库存成功");
    }


    //处理浏览器自动请求的图标文件
    @GetMapping("/favicon.ico")
    public void ico() {
    }
}
